Amendments to the Claims: 

This listing of claims will replace all prior versions, and listings, of claims in 
the application: 

Please amend the claims as follows: 

1-9. (Canceled) 

10. (Previously presented) A method implemented by a service for 
maintaining control over stored one or more applications on a data processing 
device: 

transmitting said one or more applications from a server to said data 
processing device concurrently with block allocation data indicating blocks on 
said data processing device into which said one or more applications are to be 
stored; and 

maintaining a list of all subsequent data transactions performed with said 
data processing device during end-user operation of said device, said list usable 
by said server to construct a map of all applications stored on said data 
processing device. 

11. (Original) The method as in claim 10 further comprising: 
generating said map of all applications stored on said data processing 

device prior to a new transaction with said data processing device. 

12. (Original) The method as in claim 11 wherein said new transaction is 
an application patch. 
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13. (Original) The method as in claim 11 wherein said new transaction is 
a new application download. 

14. (Original) The method as in claim 12 further comprising: 
transmitting said patch to said data processing device along with an 

indication of where said patch should overwrite a portion of said application. 

15. (Original) The method as in claim 14 wherein said indication is an 
offset in memory. 

16. (Original) The method as in claim 15 further comprising: 
loading said one or more blocks of program code into volatile memory, 
identifying said portion of said program code with said offset and 
overwriting said portion of said program code with said program code 

patch. 

17. (Original) The method as in claim 16 further comprising: 
executing an error checking algorithm to ensure said one or more blocks 

of program code containing said program code patch are valid. 

18. (Original) The method as in claim 17 further comprising: 

storing said one or more blocks of program code containing said program 
code patch to non-volatile memory. 



Appl. No. 10/053,205 

Amdt. dated Aug. 4, 2006 3 
Reply to the Office action of July 27, 2006 



04676. P01 2 



19. (Previously presented) A method comprising: 

maintaining a program code map on a server indicating how program 
code is allocated among a plurality of non-volatile memory blocks on a data 
processing device; 

using said program code map to facilitate modifications to said program 
code on said data processing device; 

maintaining a list of transactions between said server and said data 
processing device during end-user operation of said data processing device; and 

running an algorithm to construct said map in realtime using said list of 
transactions, said algorithm being an algorithm executed on said data processing 
device to store program code within said plurality of non-volatile memory blocks 
of the data processing device. 

20. (Original) The method as in claim 19 wherein using said program 
code map comprises: 

calculating a location of a program code patch within said program code; 

and 

transmitting said program code patch to said data processing device 
along with said location. 

21. (Original) The method as in claim 20 wherein said location is an 
offset in memory. 

22. (Canceled) 
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23. (Previously presented) The method as in claim 19 wherein said non- 
volatile memory blocks are flash memory blocks. 

24. (Previously presented) The method as in claim 19 wherein using said 
program code map comprises: 

identifying a specific block within said non-volatile memory to be replaced; 

transmitting said specific block to said data processing device; 

said data processing device combining said block in volatile memory with 
one or more other blocks containing program code for a specific application and 
verifying a signature of said application; and 

saving said specific block to non-volatile memory once said signature is 
verified. 

25. (Previously presented) The method as in claim 24 further comprising: 
executing a cyclical redundancy checking (CRC) to verify that said 

program code within said specific block is valid. 

26. (Currently amended) A system comprising: 

a server to transmit program code to a data processing device and to 
continual l y mon i tor during end-user operation of said data processing device to 
maintain a list of transactions between said server and said data processing 
device and to monitor (1) which program code is stored on said data processing 
device and (2) specific areas in a memory space in which said program code is 
stored on said data processing device[[,]]; and 
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the server to transfer additional program code to said data processing 
device along with storage location data indicating where in said memory said 
additional program code should be stored. 

27. (Original) The system as in claim 26 wherein said storage location 
data comprises an offset in said memory of said data processing device 
indicating where within said memory said additional program code should be 
transmitted. 

28. (Previously presented) The system as in claim 26 wherein said 
storage location data comprises one or more non-volatile memory blocks where 
said additional program code should be stored. 

29. (Original) The system as in claim 28 wherein said additional program 
code comprises a patch to a current program stored on said data processing 
device. 

30. (Original) The system as in claim 26 wherein said data processing 
device is a wireless device. 

31. (Previously presented) The system as in claim 28 wherein said server 
transfers a cyclical redundancy checking (CRC) value with each block of 
program code transmitted to said data processing device. 
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32. (Original) The system as in claim 29 wherein said server transfers an 
updated CRC value with said patch, said CRC value identifying data within a 
particular block in which said patch is required as being valid data. 

33. (Original) The system as in claim 29 wherein said server transfers an 
updated application signature usable by said data processing device to 
authenticate an application upgraded by said patch. 
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